[id].vue 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <!-- Page de détails d'un sous-domaine -->
  2. <template>
  3. <main>
  4. <LayoutContainer>
  5. <UiLoadingPanel v-if="pending" />
  6. <div v-else>
  7. <div>
  8. {{ $t('youRegisteredTheFollowingSubdomain')}} :
  9. </div>
  10. <div class="pa-8">
  11. <b>{{ subdomain.subdomain }}</b>
  12. <span class="text-on-neutral">.opentalent.fr</span>
  13. </div>
  14. <div>
  15. <div v-if="subdomain.active">
  16. <v-icon class="text-success icon small mr-2">
  17. fa-solid fa-check
  18. </v-icon>
  19. {{ $t('subdomainIsCurrentlyActive') }}
  20. </div>
  21. <div v-else>
  22. {{ $t('doYouWantToActivateThisSubdomain') }} ?
  23. </div>
  24. </div>
  25. <div class="mt-6 d-flex flex-row">
  26. <v-btn class="mr-12" @click="quit">
  27. {{ $t('back') }}
  28. </v-btn>
  29. <div v-if="!subdomain.active">
  30. <v-btn color="primary" @click="activateAndQuit" >
  31. {{ $t('activate') }}
  32. </v-btn>
  33. </div>
  34. </div>
  35. </div>
  36. </LayoutContainer>
  37. </main>
  38. </template>
  39. <script setup lang="ts">
  40. import Subdomain from "~/models/Organization/Subdomain";
  41. import {useEntityFetch} from "~/composables/data/useEntityFetch";
  42. import {useOrganizationProfileStore} from "~/stores/organizationProfile";
  43. import {useEntityManager} from "~/composables/data/useEntityManager";
  44. import {usePageStore} from "~/stores/page";
  45. import {TYPE_ALERT} from "~/types/enum/enums";
  46. import {useRefreshProfile} from "~/composables/data/useRefreshProfile";
  47. const { em } = useEntityManager()
  48. const { fetch } = useEntityFetch()
  49. const organizationProfile = useOrganizationProfileStore()
  50. const router = useRouter()
  51. const route = useRoute()
  52. const { refreshProfile } = useRefreshProfile()
  53. if (!route.params.id || isNaN(route.params.id as any)) {
  54. throw new Error('no id found')
  55. }
  56. const id: number = parseInt(route.params.id as string)
  57. const { data: subdomain, pending } = fetch(Subdomain, id)
  58. const activationPending: Ref<boolean> = ref(false)
  59. const pageStore = usePageStore()
  60. const activateAndQuit = async () => {
  61. activationPending.value = true
  62. pageStore.loading = true
  63. await em.patch(Subdomain, id, { active: true} )
  64. await refreshProfile()
  65. usePageStore().addAlert(TYPE_ALERT.SUCCESS, ['subdomain_activated_and_available_in_a_few_minutes'])
  66. quit()
  67. }
  68. const quit = () => {
  69. router.push('/parameters?tab=website')
  70. activationPending.value = false
  71. pageStore.loading = false
  72. }
  73. </script>